home *** CD-ROM | disk | FTP | other *** search
/ BCI NET 2 / BCI NET 2.iso / archives / programming / source / a2.0bemacs-src.lha / Emacs-19.25 / lisp / trace.elc < prev    next >
Emacs Compiled Lisp  |  1993-11-24  |  4.4 KB

open in: MacOS 8.1     |     Win98     |     DOS

view JSON data     |     view as text

This file was processed as: Emacs Compiled Lisp (other/emacsCompiledLisp).
This format is not currently supported by dexvert.

ConfidenceProgramDetectionMatch TypeSupport
1% dexvert Emacs Compiled Lisp (other/emacsCompiledLisp) magic Unsupported
100% file Emacs/XEmacs v19 byte-compiled Lisp data default
99% file data default
100% TrID Emacs/XEmacs byte-compiled Lisp (generic) default



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 3b 45 4c 43 13 00 00 00 | 0a 3b 3b 3b 20 63 6f 6d |;ELC....|.;;; com|
|00000010| 70 69 6c 65 64 20 62 79 | 20 72 6d 73 40 6d 6f 6c |piled by| rms@mol|
|00000020| 65 2e 67 6e 75 2e 61 69 | 2e 6d 69 74 2e 65 64 75 |e.gnu.ai|.mit.edu|
|00000030| 20 6f 6e 20 57 65 64 20 | 4e 6f 76 20 32 34 20 30 | on Wed |Nov 24 0|
|00000040| 34 3a 31 39 3a 34 36 20 | 31 39 39 33 0a 3b 3b 3b |4:19:46 |1993.;;;|
|00000050| 20 66 72 6f 6d 20 66 69 | 6c 65 20 2f 68 6f 6d 65 | from fi|le /home|
|00000060| 2f 66 73 66 2f 72 6d 73 | 2f 65 31 39 2f 6c 69 73 |/fsf/rms|/e19/lis|
|00000070| 70 2f 74 72 61 63 65 2e | 65 6c 0a 3b 3b 3b 20 65 |p/trace.|el.;;; e|
|00000080| 6d 61 63 73 20 76 65 72 | 73 69 6f 6e 20 31 39 2e |macs ver|sion 19.|
|00000090| 32 31 2e 32 2e 0a 3b 3b | 3b 20 62 79 74 65 63 6f |21.2..;;|; byteco|
|000000a0| 6d 70 20 76 65 72 73 69 | 6f 6e 20 46 53 46 20 32 |mp versi|on FSF 2|
|000000b0| 2e 31 30 0a 3b 3b 3b 20 | 6f 70 74 69 6d 69 7a 61 |.10.;;; |optimiza|
|000000c0| 74 69 6f 6e 20 69 73 20 | 6f 6e 2e 0a 3b 3b 3b 20 |tion is |on..;;; |
|000000d0| 74 68 69 73 20 66 69 6c | 65 20 75 73 65 73 20 6f |this fil|e uses o|
|000000e0| 70 63 6f 64 65 73 20 77 | 68 69 63 68 20 64 6f 20 |pcodes w|hich do |
|000000f0| 6e 6f 74 20 65 78 69 73 | 74 20 69 6e 20 45 6d 61 |not exis|t in Ema|
|00000100| 63 73 20 31 38 2e 0a 0a | 28 69 66 20 28 61 6e 64 |cs 18...|(if (and|
|00000110| 20 28 62 6f 75 6e 64 70 | 20 27 65 6d 61 63 73 2d | (boundp| 'emacs-|
|00000120| 76 65 72 73 69 6f 6e 29 | 0a 09 20 28 6f 72 20 28 |version)|.. (or (|
|00000130| 61 6e 64 20 28 62 6f 75 | 6e 64 70 20 27 65 70 6f |and (bou|ndp 'epo|
|00000140| 63 68 3a 3a 76 65 72 73 | 69 6f 6e 29 20 65 70 6f |ch::vers|ion) epo|
|00000150| 63 68 3a 3a 76 65 72 73 | 69 6f 6e 29 0a 09 20 20 |ch::vers|ion).. |
|00000160| 20 20 20 28 73 74 72 69 | 6e 67 2d 6c 65 73 73 70 | (stri|ng-lessp|
|00000170| 20 65 6d 61 63 73 2d 76 | 65 72 73 69 6f 6e 20 22 | emacs-v|ersion "|
|00000180| 31 39 22 29 29 29 0a 20 | 20 20 20 28 65 72 72 6f |19"))). | (erro|
|00000190| 72 20 22 54 68 69 73 20 | 66 69 6c 65 20 77 61 73 |r "This |file was|
|000001a0| 20 63 6f 6d 70 69 6c 65 | 64 20 66 6f 72 20 45 6d | compile|d for Em|
|000001b0| 61 63 73 20 31 39 22 29 | 29 0a 0a 28 62 79 74 65 |acs 19")|)..(byte|
|000001c0| 2d 63 6f 64 65 20 22 c0 | c1 21 88 c2 c3 21 84 0f |-code ".|.!...!..|
|000001d0| 00 c4 c3 c5 5c 22 88 c6 | 16 07 c0 87 22 20 5b 72 |....\"..|...." [r|
|000001e0| 65 71 75 69 72 65 20 61 | 64 76 69 63 65 20 66 62 |equire a|dvice fb|
|000001f0| 6f 75 6e 64 70 20 5c 60 | 20 61 75 74 6f 6c 6f 61 |oundp \`| autoloa|
|00000200| 64 20 22 62 61 63 6b 71 | 75 6f 74 65 22 20 22 32 |d "backq|uote" "2|
|00000210| 2e 30 22 20 74 72 61 63 | 65 2d 76 65 72 73 69 6f |.0" trac|e-versio|
|00000220| 6e 5d 20 33 29 0a 28 64 | 65 66 76 61 72 20 74 72 |n] 3).(d|efvar tr|
|00000230| 61 63 65 2d 62 75 66 66 | 65 72 20 22 2a 74 72 61 |ace-buff|er "*tra|
|00000240| 63 65 2d 6f 75 74 70 75 | 74 2a 22 20 22 5c 0a 2a |ce-outpu|t*" "\.*|
|00000250| 54 72 61 63 65 20 6f 75 | 74 70 75 74 20 77 69 6c |Trace ou|tput wil|
|00000260| 6c 20 62 79 20 64 65 66 | 61 75 6c 74 20 67 6f 20 |l by def|ault go |
|00000270| 74 6f 20 74 68 61 74 20 | 62 75 66 66 65 72 2e 22 |to that |buffer."|
|00000280| 29 0a 28 62 79 74 65 2d | 63 6f 64 65 20 22 c0 c1 |).(byte-|code "..|
|00000290| 21 84 08 00 c2 11 c0 c3 | 21 84 10 00 c4 13 c0 c5 |!.......|!.......|
|000002a0| 21 84 1e 00 c6 c7 c8 c9 | ca 5c 22 5c 22 15 cb cc |!.......|.\"\"...|
|000002b0| cd 5c 22 88 cb ce cf 5c | 22 88 cb d0 d1 5c 22 88 |.\"....\|"....\".|
|000002c0| cb d2 d3 5c 22 88 cb d4 | d5 5c 22 87 22 20 5b 62 |...\"...|.\"." [b|
|000002d0| 6f 75 6e 64 70 20 74 72 | 61 63 65 2d 6c 65 76 65 |oundp tr|ace-leve|
|000002e0| 6c 20 30 20 74 72 61 63 | 65 2d 61 64 76 69 63 65 |l 0 trac|e-advice|
|000002f0| 2d 6e 61 6d 65 20 74 72 | 61 63 65 2d 66 75 6e 63 |-name tr|ace-func|
|00000300| 74 69 6f 6e 5c 20 20 74 | 72 61 63 65 2d 73 65 70 |tion\ t|race-sep|
|00000310| 61 72 61 74 6f 72 20 66 | 6f 72 6d 61 74 20 22 25 |arator f|ormat "%|
|00000320| 73 5c 6e 22 20 6d 61 6b | 65 2d 73 74 72 69 6e 67 |s\n" mak|e-string|
|00000330| 20 37 30 20 36 31 20 64 | 65 66 61 6c 69 61 73 20 | 70 61 d|efalias |
|00000340| 74 72 61 63 65 2d 65 6e | 74 72 79 2d 6d 65 73 73 |trace-en|try-mess|
|00000350| 61 67 65 20 23 5b 28 66 | 75 6e 63 74 69 6f 6e 20 |age #[(f|unction |
|00000360| 6c 65 76 65 6c 20 61 72 | 67 75 6d 65 6e 74 2d 62 |level ar|gument-b|
|00000370| 69 6e 64 69 6e 67 73 29 | 20 22 c0 c1 c2 c3 c4 0d |indings)| "......|
|00000380| 53 c6 5c 22 c7 23 0d c8 | 56 83 15 00 c7 82 16 00 |S.\".#..|V.......|
|00000390| c9 0d 0e 5c 6e c2 cb 0e | 0c c7 23 26 06 87 22 20 |...\n...|..#&.." |
|000003a0| 5b 66 6f 72 6d 61 74 20 | 22 25 73 25 73 25 64 20 |[format |"%s%s%d |
|000003b0| 2d 3e 20 25 73 3a 20 25 | 73 5c 6e 22 20 6d 61 70 |-> %s: %|s\n" map|
|000003c0| 63 6f 6e 63 61 74 20 63 | 68 61 72 2d 74 6f 2d 73 |concat c|har-to-s|
|000003d0| 74 72 69 6e 67 20 6d 61 | 6b 65 2d 73 74 72 69 6e |tring ma|ke-strin|
|000003e0| 67 20 6c 65 76 65 6c 20 | 31 32 34 20 22 20 22 20 |g level |124 " " |
|000003f0| 31 20 22 22 20 66 75 6e | 63 74 69 6f 6e 20 23 5b |1 "" fun|ction #[|
|00000400| 28 62 69 6e 64 69 6e 67 | 29 20 22 c0 c1 5c 6e c3 |(binding|) "..\n.|
|00000410| 5c 22 21 c4 c5 c1 5c 6e | c6 5c 22 21 51 87 22 20 |\"!...\n|.\"!Q." |
|00000420| 5b 73 79 6d 62 6f 6c 2d | 6e 61 6d 65 20 61 64 2d |[symbol-|name ad-|
|00000430| 61 72 67 2d 62 69 6e 64 | 69 6e 67 2d 66 69 65 6c |arg-bind|ing-fiel|
|00000440| 64 20 62 69 6e 64 69 6e | 67 20 6e 61 6d 65 20 22 |d bindin|g name "|
|00000450| 3d 22 20 70 72 69 6e 31 | 2d 74 6f 2d 73 74 72 69 |=" prin1|-to-stri|
|00000460| 6e 67 20 76 61 6c 75 65 | 5d 20 36 5d 20 61 72 67 |ng value|] 6] arg|
|00000470| 75 6d 65 6e 74 2d 62 69 | 6e 64 69 6e 67 73 5d 20 |ument-bi|ndings] |
|00000480| 31 30 5d 20 74 72 61 63 | 65 2d 65 78 69 74 2d 6d |10] trac|e-exit-m|
|00000490| 65 73 73 61 67 65 20 23 | 5b 28 66 75 6e 63 74 69 |essage #|[(functi|
|000004a0| 6f 6e 20 6c 65 76 65 6c | 20 76 61 6c 75 65 29 20 |on level| value) |
|000004b0| 22 c0 c1 c2 c3 c4 0d 53 | c6 5c 22 c7 23 0d c8 56 |"......S|.\".#..V|
|000004c0| 83 15 00 c7 82 16 00 c9 | 0d 0e 5c 6e cb 0e 0c 21 |........|..\n...!|
|000004d0| 26 06 87 22 20 5b 66 6f | 72 6d 61 74 20 22 25 73 |&.." [fo|rmat "%s|
|000004e0| 25 73 25 64 20 3c 2d 20 | 25 73 3a 20 25 73 5c 6e |%s%d <- |%s: %s\n|
|000004f0| 22 20 6d 61 70 63 6f 6e | 63 61 74 20 63 68 61 72 |" mapcon|cat char|
|00000500| 2d 74 6f 2d 73 74 72 69 | 6e 67 20 6d 61 6b 65 2d |-to-stri|ng make-|
|00000510| 73 74 72 69 6e 67 20 6c | 65 76 65 6c 20 31 32 34 |string l|evel 124|
|00000520| 20 22 20 22 20 31 20 22 | 22 20 66 75 6e 63 74 69 | " " 1 "|" functi|
|00000530| 6f 6e 20 70 72 69 6e 31 | 2d 74 6f 2d 73 74 72 69 |on prin1|-to-stri|
|00000540| 6e 67 20 76 61 6c 75 65 | 5d 20 38 5d 20 74 72 61 |ng value|] 8] tra|
|00000550| 63 65 2d 6d 61 6b 65 2d | 61 64 76 69 63 65 20 23 |ce-make-|advice #|
|00000560| 5b 28 66 75 6e 63 74 69 | 6f 6e 20 62 75 66 66 65 |[(functi|on buffe|
|00000570| 72 20 62 61 63 6b 67 72 | 6f 75 6e 64 29 20 22 c0 |r backgr|ound) ".|
|00000580| 09 c2 c3 0c 83 39 00 c5 | c6 c2 c7 c8 c9 ca 0e 0b |.....9..|........|
|00000590| 44 44 44 cc cd ce cf d0 | d1 d2 0e 13 44 d4 d5 46 |DDD.....|....D..F|
|000005a0| 44 af 05 d6 cc d7 d8 d0 | d9 d2 0e 13 44 d4 da 46 |D.......|....D..F|
|000005b0| 44 46 af 05 46 82 62 00 | c5 c6 c2 c7 db c9 ca 0e |DF..F.b.|........|
|000005c0| 0b 44 44 44 dc dd de d0 | d1 d2 0e 13 44 d4 d5 46 |.DDD....|....D..F|
|000005d0| 44 d6 df e0 d0 d9 d2 0e | 13 44 d4 da 46 44 af 5c |D.......|.D..FD.\|
|000005e0| 6e 46 24 87 22 20 5b 61 | 64 2d 6d 61 6b 65 2d 61 |nF$." [a|d-make-a|
|000005f0| 64 76 69 63 65 20 74 72 | 61 63 65 2d 61 64 76 69 |dvice tr|ace-advi|
|00000600| 63 65 2d 6e 61 6d 65 20 | 6e 69 6c 20 74 20 62 61 |ce-name |nil t ba|
|00000610| 63 6b 67 72 6f 75 6e 64 | 20 61 64 76 69 63 65 20 |ckground| advice |
|00000620| 6c 61 6d 62 64 61 20 6c | 65 74 20 28 74 72 61 63 |lambda l|et (trac|
|00000630| 65 2d 6c 65 76 65 6c 20 | 28 31 2b 20 74 72 61 63 |e-level |(1+ trac|
|00000640| 65 2d 6c 65 76 65 6c 29 | 29 20 74 72 61 63 65 2d |e-level)|) trace-|
|00000650| 62 75 66 66 65 72 20 67 | 65 74 2d 62 75 66 66 65 |buffer g|et-buffe|
|00000660| 72 2d 63 72 65 61 74 65 | 20 62 75 66 66 65 72 20 |r-create| buffer |
|00000670| 73 61 76 65 2d 65 78 63 | 75 72 73 69 6f 6e 20 28 |save-exc|ursion (|
|00000680| 73 65 74 2d 62 75 66 66 | 65 72 20 74 72 61 63 65 |set-buff|er trace|
|00000690| 2d 62 75 66 66 65 72 29 | 20 28 67 6f 74 6f 2d 63 |-buffer)| (goto-c|
|000006a0| 68 61 72 20 28 70 6f 69 | 6e 74 2d 6d 61 78 29 29 |har (poi|nt-max))|
|000006b0| 20 28 69 66 20 28 3d 20 | 74 72 61 63 65 2d 6c 65 | (if (= |trace-le|
|000006c0| 76 65 6c 20 31 29 20 28 | 69 6e 73 65 72 74 20 74 |vel 1) (|insert t|
|000006d0| 72 61 63 65 2d 73 65 70 | 61 72 61 74 6f 72 29 29 |race-sep|arator))|
|000006e0| 20 69 6e 73 65 72 74 20 | 74 72 61 63 65 2d 65 6e | insert |trace-en|
|000006f0| 74 72 79 2d 6d 65 73 73 | 61 67 65 20 71 75 6f 74 |try-mess|age quot|
|00000700| 65 20 66 75 6e 63 74 69 | 6f 6e 20 74 72 61 63 65 |e functi|on trace|
|00000710| 2d 6c 65 76 65 6c 20 61 | 64 2d 61 72 67 2d 62 69 |-level a|d-arg-bi|
|00000720| 6e 64 69 6e 67 73 20 61 | 64 2d 64 6f 2d 69 74 20 |ndings a|d-do-it |
|00000730| 28 73 65 74 2d 62 75 66 | 66 65 72 20 74 72 61 63 |(set-buf|fer trac|
|00000740| 65 2d 62 75 66 66 65 72 | 29 20 28 67 6f 74 6f 2d |e-buffer|) (goto-|
|00000750| 63 68 61 72 20 28 70 6f | 69 6e 74 2d 6d 61 78 29 |char (po|int-max)|
|00000760| 29 20 74 72 61 63 65 2d | 65 78 69 74 2d 6d 65 73 |) trace-|exit-mes|
|00000770| 73 61 67 65 20 61 64 2d | 72 65 74 75 72 6e 2d 76 |sage ad-|return-v|
|00000780| 61 6c 75 65 20 28 74 72 | 61 63 65 2d 6c 65 76 65 |alue (tr|ace-leve|
|00000790| 6c 20 28 31 2b 20 74 72 | 61 63 65 2d 6c 65 76 65 |l (1+ tr|ace-leve|
|000007a0| 6c 29 29 20 28 70 6f 70 | 2d 74 6f 2d 62 75 66 66 |l)) (pop|-to-buff|
|000007b0| 65 72 20 74 72 61 63 65 | 2d 62 75 66 66 65 72 29 |er trace|-buffer)|
|000007c0| 20 28 67 6f 74 6f 2d 63 | 68 61 72 20 28 70 6f 69 | (goto-c|har (poi|
|000007d0| 6e 74 2d 6d 61 78 29 29 | 20 28 69 66 20 28 3d 20 |nt-max))| (if (= |
|000007e0| 74 72 61 63 65 2d 6c 65 | 76 65 6c 20 31 29 20 28 |trace-le|vel 1) (|
|000007f0| 69 6e 73 65 72 74 20 74 | 72 61 63 65 2d 73 65 70 |insert t|race-sep|
|00000800| 61 72 61 74 6f 72 29 29 | 20 28 70 6f 70 2d 74 6f |arator))| (pop-to|
|00000810| 2d 62 75 66 66 65 72 20 | 74 72 61 63 65 2d 62 75 |-buffer |trace-bu|
|00000820| 66 66 65 72 29 20 28 67 | 6f 74 6f 2d 63 68 61 72 |ffer) (g|oto-char|
|00000830| 20 28 70 6f 69 6e 74 2d | 6d 61 78 29 29 5d 20 32 | (point-|max))] 2|
|00000840| 31 5d 20 74 72 61 63 65 | 2d 66 75 6e 63 74 69 6f |1] trace|-functio|
|00000850| 6e 2d 69 6e 74 65 72 6e | 61 6c 20 23 5b 28 66 75 |n-intern|al #[(fu|
|00000860| 6e 63 74 69 6f 6e 20 62 | 75 66 66 65 72 20 62 61 |nction b|uffer ba|
|00000870| 63 6b 67 72 6f 75 6e 64 | 29 20 22 c0 09 c2 09 0b |ckground|) ".....|
|00000880| 86 09 00 0c 0d 23 c6 c7 | 24 88 c8 09 c9 5c 22 87 |.....#..|$....\".|
|00000890| 22 20 5b 61 64 2d 61 64 | 64 2d 61 64 76 69 63 65 |" [ad-ad|d-advice|
|000008a0| 20 66 75 6e 63 74 69 6f | 6e 20 74 72 61 63 65 2d | functio|n trace-|
|000008b0| 6d 61 6b 65 2d 61 64 76 | 69 63 65 20 62 75 66 66 |make-adv|ice buff|
|000008c0| 65 72 20 74 72 61 63 65 | 2d 62 75 66 66 65 72 20 |er trace|-buffer |
|000008d0| 62 61 63 6b 67 72 6f 75 | 6e 64 20 61 72 6f 75 6e |backgrou|nd aroun|
|000008e0| 64 20 6c 61 73 74 20 61 | 64 2d 61 63 74 69 76 61 |d last a|d-activa|
|000008f0| 74 65 20 6e 69 6c 5d 20 | 36 5d 20 74 72 61 63 65 |te nil] |6] trace|
|00000900| 2d 69 73 2d 74 72 61 63 | 65 64 20 23 5b 28 66 75 |-is-trac|ed #[(fu|
|00000910| 6e 63 74 69 6f 6e 29 20 | 22 08 c1 5c 6e c3 4e 9e |nction) |"..\n.N.|
|00000920| 41 9e 87 22 20 5b 74 72 | 61 63 65 2d 61 64 76 69 |A.." [tr|ace-advi|
|00000930| 63 65 2d 6e 61 6d 65 20 | 61 72 6f 75 6e 64 20 66 |ce-name |around f|
|00000940| 75 6e 63 74 69 6f 6e 20 | 61 64 2d 61 64 76 69 63 |unction |ad-advic|
|00000950| 65 2d 69 6e 66 6f 5d 20 | 34 5d 5d 20 35 29 0a 28 |e-info] |4]] 5).(|
|00000960| 64 65 66 61 6c 69 61 73 | 20 27 74 72 61 63 65 2d |defalias| 'trace-|
|00000970| 66 75 6e 63 74 69 6f 6e | 20 23 5b 28 66 75 6e 63 |function| #[(func|
|00000980| 74 69 6f 6e 20 26 6f 70 | 74 69 6f 6e 61 6c 20 62 |tion &op|tional b|
|00000990| 75 66 66 65 72 29 20 22 | c0 09 5c 6e c3 23 87 22 |uffer) "|..\n.#."|
|000009a0| 20 5b 74 72 61 63 65 2d | 66 75 6e 63 74 69 6f 6e | [trace-|function|
|000009b0| 2d 69 6e 74 65 72 6e 61 | 6c 20 66 75 6e 63 74 69 |-interna|l functi|
|000009c0| 6f 6e 20 62 75 66 66 65 | 72 20 6e 69 6c 5d 20 34 |on buffe|r nil] 4|
|000009d0| 20 22 5c 0a 54 72 61 63 | 65 73 20 46 55 4e 43 54 | "\.Trac|es FUNCT|
|000009e0| 49 4f 4e 20 77 69 74 68 | 20 74 72 61 63 65 20 6f |ION with| trace o|
|000009f0| 75 74 70 75 74 20 67 6f | 69 6e 67 20 74 6f 20 42 |utput go|ing to B|
|00000a00| 55 46 46 45 52 2e 0a 46 | 6f 72 20 65 76 65 72 79 |UFFER..F|or every|
|00000a10| 20 63 61 6c 6c 20 6f 66 | 20 46 55 4e 43 54 49 4f | call of| FUNCTIO|
|00000a20| 4e 20 4c 69 73 70 2d 73 | 74 79 6c 65 20 74 72 61 |N Lisp-s|tyle tra|
|00000a30| 63 65 20 6d 65 73 73 61 | 67 65 73 20 74 68 61 74 |ce messa|ges that|
|00000a40| 20 64 69 73 70 6c 61 79 | 20 61 72 67 75 6d 65 6e | display| argumen|
|00000a50| 74 0a 61 6e 64 20 72 65 | 74 75 72 6e 20 76 61 6c |t.and re|turn val|
|00000a60| 75 65 73 20 77 69 6c 6c | 20 62 65 20 69 6e 73 65 |ues will| be inse|
|00000a70| 72 74 65 64 20 69 6e 74 | 6f 20 42 55 46 46 45 52 |rted int|o BUFFER|
|00000a80| 2e 20 54 68 69 73 20 66 | 75 6e 63 74 69 6f 6e 20 |. This f|unction |
|00000a90| 67 65 6e 65 72 61 74 65 | 73 20 74 68 65 0a 74 72 |generate|s the.tr|
|00000aa0| 61 63 65 20 61 64 76 69 | 63 65 20 66 6f 72 20 46 |ace advi|ce for F|
|00000ab0| 55 4e 43 54 49 4f 4e 20 | 61 6e 64 20 61 63 74 69 |UNCTION |and acti|
|00000ac0| 76 61 74 65 73 20 69 74 | 20 74 6f 67 65 74 68 65 |vates it| togethe|
|00000ad0| 72 20 77 69 74 68 20 61 | 6e 79 20 6f 74 68 65 72 |r with a|ny other|
|00000ae0| 20 61 64 76 69 63 65 0a | 74 68 65 72 65 20 6d 69 | advice.|there mi|
|00000af0| 67 68 74 20 62 65 21 21 | 20 54 68 65 20 74 72 61 |ght be!!| The tra|
|00000b00| 63 65 20 42 55 46 46 45 | 52 20 77 69 6c 6c 20 70 |ce BUFFE|R will p|
|00000b10| 6f 70 75 70 20 77 68 65 | 6e 65 76 65 72 20 46 55 |opup whe|never FU|
|00000b20| 4e 43 54 49 4f 4e 20 69 | 73 20 63 61 6c 6c 65 64 |NCTION i|s called|
|00000b30| 2e 0a 44 6f 20 6e 6f 74 | 20 75 73 65 20 74 68 69 |..Do not| use thi|
|00000b40| 73 20 74 6f 20 74 72 61 | 63 65 20 66 75 6e 63 74 |s to tra|ce funct|
|00000b50| 69 6f 6e 73 20 74 68 61 | 74 20 73 77 69 74 63 68 |ions tha|t switch|
|00000b60| 20 62 75 66 66 65 72 73 | 20 6f 72 20 64 6f 20 61 | buffers| or do a|
|00000b70| 6e 79 20 6f 74 68 65 72 | 0a 64 69 73 70 6c 61 79 |ny other|.display|
|00000b80| 20 6f 72 69 65 6e 74 65 | 64 20 73 74 75 66 66 2c | oriente|d stuff,|
|00000b90| 20 75 73 65 20 60 74 72 | 61 63 65 2d 66 75 6e 63 | use `tr|ace-func|
|00000ba0| 74 69 6f 6e 2d 62 61 63 | 6b 67 72 6f 75 6e 64 27 |tion-bac|kground'|
|00000bb0| 20 69 6e 73 74 65 61 64 | 2e 22 20 28 6c 69 73 74 | instead|." (list|
|00000bc0| 20 28 69 6e 74 65 72 6e | 20 28 63 6f 6d 70 6c 65 | (intern| (comple|
|00000bd0| 74 69 6e 67 2d 72 65 61 | 64 20 22 54 72 61 63 65 |ting-rea|d "Trace|
|00000be0| 20 66 75 6e 63 74 69 6f | 6e 3a 20 22 20 6f 62 61 | functio|n: " oba|
|00000bf0| 72 72 61 79 20 28 71 75 | 6f 74 65 20 66 62 6f 75 |rray (qu|ote fbou|
|00000c00| 6e 64 70 29 20 74 29 29 | 20 28 72 65 61 64 2d 62 |ndp) t))| (read-b|
|00000c10| 75 66 66 65 72 20 22 4f | 75 74 70 75 74 20 74 6f |uffer "O|utput to|
|00000c20| 20 62 75 66 66 65 72 3a | 20 22 20 74 72 61 63 65 | buffer:| " trace|
|00000c30| 2d 62 75 66 66 65 72 29 | 29 5d 29 0a 28 64 65 66 |-buffer)|)]).(def|
|00000c40| 61 6c 69 61 73 20 27 74 | 72 61 63 65 2d 66 75 6e |alias 't|race-fun|
|00000c50| 63 74 69 6f 6e 2d 62 61 | 63 6b 67 72 6f 75 6e 64 |ction-ba|ckground|
|00000c60| 20 23 5b 28 66 75 6e 63 | 74 69 6f 6e 20 26 6f 70 | #[(func|tion &op|
|00000c70| 74 69 6f 6e 61 6c 20 62 | 75 66 66 65 72 29 20 22 |tional b|uffer) "|
|00000c80| c0 09 5c 6e c3 23 87 22 | 20 5b 74 72 61 63 65 2d |..\n.#."| [trace-|
|00000c90| 66 75 6e 63 74 69 6f 6e | 2d 69 6e 74 65 72 6e 61 |function|-interna|
|00000ca0| 6c 20 66 75 6e 63 74 69 | 6f 6e 20 62 75 66 66 65 |l functi|on buffe|
|00000cb0| 72 20 74 5d 20 34 20 22 | 5c 0a 54 72 61 63 65 73 |r t] 4 "|\.Traces|
|00000cc0| 20 46 55 4e 43 54 49 4f | 4e 20 77 69 74 68 20 74 | FUNCTIO|N with t|
|00000cd0| 72 61 63 65 20 6f 75 74 | 70 75 74 20 67 6f 69 6e |race out|put goin|
|00000ce0| 67 20 71 75 69 65 74 6c | 79 20 74 6f 20 42 55 46 |g quietl|y to BUF|
|00000cf0| 46 45 52 2e 0a 46 6f 72 | 20 65 76 65 72 79 20 63 |FER..For| every c|
|00000d00| 61 6c 6c 20 6f 66 20 46 | 55 4e 43 54 49 4f 4e 20 |all of F|UNCTION |
|00000d10| 4c 69 73 70 2d 73 74 79 | 6c 65 20 74 72 61 63 65 |Lisp-sty|le trace|
|00000d20| 20 6d 65 73 73 61 67 65 | 73 20 74 68 61 74 20 64 | message|s that d|
|00000d30| 69 73 70 6c 61 79 20 61 | 72 67 75 6d 65 6e 74 0a |isplay a|rgument.|
|00000d40| 61 6e 64 20 72 65 74 75 | 72 6e 20 76 61 6c 75 65 |and retu|rn value|
|00000d50| 73 20 77 69 6c 6c 20 62 | 65 20 69 6e 73 65 72 74 |s will b|e insert|
|00000d60| 65 64 20 69 6e 74 6f 20 | 42 55 46 46 45 52 2e 20 |ed into |BUFFER. |
|00000d70| 54 68 69 73 20 66 75 6e | 63 74 69 6f 6e 20 67 65 |This fun|ction ge|
|00000d80| 6e 65 72 61 74 65 73 20 | 74 68 65 0a 74 72 61 63 |nerates |the.trac|
|00000d90| 65 20 61 64 76 69 63 65 | 20 66 6f 72 20 46 55 4e |e advice| for FUN|
|00000da0| 43 54 49 4f 4e 20 61 6e | 64 20 61 63 74 69 76 61 |CTION an|d activa|
|00000db0| 74 65 73 20 69 74 20 74 | 6f 67 65 74 68 65 72 20 |tes it t|ogether |
|00000dc0| 77 69 74 68 20 61 6e 79 | 20 6f 74 68 65 72 20 61 |with any| other a|
|00000dd0| 64 76 69 63 65 0a 74 68 | 65 72 65 20 6d 69 67 68 |dvice.th|ere migh|
|00000de0| 74 20 62 65 21 21 20 54 | 72 61 63 65 20 6f 75 74 |t be!! T|race out|
|00000df0| 70 75 74 20 77 69 6c 6c | 20 71 75 69 65 74 6c 79 |put will| quietly|
|00000e00| 20 67 6f 20 74 6f 20 42 | 55 46 46 45 52 20 77 69 | go to B|UFFER wi|
|00000e10| 74 68 6f 75 74 20 63 68 | 61 6e 67 69 6e 67 0a 74 |thout ch|anging.t|
|00000e20| 68 65 20 77 69 6e 64 6f | 77 20 6f 72 20 62 75 66 |he windo|w or buf|
|00000e30| 66 65 72 20 63 6f 6e 66 | 69 67 75 72 61 74 69 6f |fer conf|iguratio|
|00000e40| 6e 20 61 74 20 61 6c 6c | 2e 22 20 28 6c 69 73 74 |n at all|." (list|
|00000e50| 20 28 69 6e 74 65 72 6e | 20 28 63 6f 6d 70 6c 65 | (intern| (comple|
|00000e60| 74 69 6e 67 2d 72 65 61 | 64 20 22 54 72 61 63 65 |ting-rea|d "Trace|
|00000e70| 20 66 75 6e 63 74 69 6f | 6e 20 69 6e 20 62 61 63 | functio|n in bac|
|00000e80| 6b 67 72 6f 75 6e 64 3a | 20 22 20 6f 62 61 72 72 |kground:| " obarr|
|00000e90| 61 79 20 28 71 75 6f 74 | 65 20 66 62 6f 75 6e 64 |ay (quot|e fbound|
|00000ea0| 70 29 20 74 29 29 20 28 | 72 65 61 64 2d 62 75 66 |p) t)) (|read-buf|
|00000eb0| 66 65 72 20 22 4f 75 74 | 70 75 74 20 74 6f 20 62 |fer "Out|put to b|
|00000ec0| 75 66 66 65 72 3a 20 22 | 20 74 72 61 63 65 2d 62 |uffer: "| trace-b|
|00000ed0| 75 66 66 65 72 29 29 5d | 29 0a 28 64 65 66 61 6c |uffer))]|).(defal|
|00000ee0| 69 61 73 20 27 75 6e 74 | 72 61 63 65 2d 66 75 6e |ias 'unt|race-fun|
|00000ef0| 63 74 69 6f 6e 20 23 5b | 28 66 75 6e 63 74 69 6f |ction #[|(functio|
|00000f00| 6e 29 20 22 c0 09 21 85 | 0f 00 c2 09 c3 0c 23 88 |n) "..!.|......#.|
|00000f10| c5 09 21 87 22 20 5b 74 | 72 61 63 65 2d 69 73 2d |..!." [t|race-is-|
|00000f20| 74 72 61 63 65 64 20 66 | 75 6e 63 74 69 6f 6e 20 |traced f|unction |
|00000f30| 61 64 2d 72 65 6d 6f 76 | 65 2d 61 64 76 69 63 65 |ad-remov|e-advice|
|00000f40| 20 61 72 6f 75 6e 64 20 | 74 72 61 63 65 2d 61 64 | around |trace-ad|
|00000f50| 76 69 63 65 2d 6e 61 6d | 65 20 61 64 2d 75 70 64 |vice-nam|e ad-upd|
|00000f60| 61 74 65 5d 20 34 20 22 | 5c 0a 55 6e 74 72 61 63 |ate] 4 "|\.Untrac|
|00000f70| 65 73 20 46 55 4e 43 54 | 49 4f 4e 20 61 6e 64 20 |es FUNCT|ION and |
|00000f80| 70 6f 73 73 69 62 6c 79 | 20 61 63 74 69 76 61 74 |possibly| activat|
|00000f90| 65 73 20 61 6c 6c 20 72 | 65 6d 61 69 6e 69 6e 67 |es all r|emaining|
|00000fa0| 20 61 64 76 69 63 65 2e | 0a 41 63 74 69 76 61 74 | advice.|.Activat|
|00000fb0| 69 6f 6e 20 69 73 20 70 | 65 72 66 6f 72 6d 65 64 |ion is p|erformed|
|00000fc0| 20 77 69 74 68 20 60 61 | 64 2d 75 70 64 61 74 65 | with `a|d-update|
|00000fd0| 27 2c 20 68 65 6e 63 65 | 20 72 65 6d 61 69 6e 69 |', hence| remaini|
|00000fe0| 6e 67 20 61 64 76 69 63 | 65 20 77 69 6c 6c 20 67 |ng advic|e will g|
|00000ff0| 65 74 0a 61 63 74 69 76 | 61 74 65 64 20 6f 6e 6c |et.activ|ated onl|
|00001000| 79 20 69 66 20 74 68 65 | 20 61 64 76 69 63 65 20 |y if the| advice |
|00001010| 6f 66 20 46 55 4e 43 54 | 49 4f 4e 20 69 73 20 63 |of FUNCT|ION is c|
|00001020| 75 72 72 65 6e 74 6c 79 | 20 61 63 74 69 76 65 2e |urrently| active.|
|00001030| 20 49 66 20 46 55 4e 43 | 54 49 4f 4e 0a 77 61 73 | If FUNC|TION.was|
|00001040| 20 6e 6f 74 20 74 72 61 | 63 65 64 20 74 68 69 73 | not tra|ced this|
|00001050| 20 69 73 20 61 20 6e 6f | 6f 70 2e 22 20 28 6c 69 | is a no|op." (li|
|00001060| 73 74 20 28 61 64 2d 72 | 65 61 64 2d 61 64 76 69 |st (ad-r|ead-advi|
|00001070| 73 65 64 2d 66 75 6e 63 | 74 69 6f 6e 20 22 55 6e |sed-func|tion "Un|
|00001080| 74 72 61 63 65 20 66 75 | 6e 63 74 69 6f 6e 3a 20 |trace fu|nction: |
|00001090| 22 20 28 71 75 6f 74 65 | 20 74 72 61 63 65 2d 69 |" (quote| trace-i|
|000010a0| 73 2d 74 72 61 63 65 64 | 29 29 29 5d 29 0a 28 64 |s-traced|)))]).(d|
|000010b0| 65 66 61 6c 69 61 73 20 | 27 75 6e 74 72 61 63 65 |efalias |'untrace|
|000010c0| 2d 61 6c 6c 20 23 5b 6e | 69 6c 20 22 08 c1 1a 89 |-all #[n|il "....|
|000010d0| 1b 83 1b 00 0b 40 12 c4 | 5c 6e 40 21 12 c5 5c 6e |.....@..|\n@!..\n|
|000010e0| 21 88 0b 41 89 13 84 08 | 00 2a c1 87 22 20 5b 61 |!..A....|.*.." [a|
|000010f0| 64 2d 61 64 76 69 73 65 | 64 2d 66 75 6e 63 74 69 |d-advise|d-functi|
|00001100| 6f 6e 73 20 6e 69 6c 20 | 66 75 6e 63 74 69 6f 6e |ons nil |function|
|00001110| 20 61 64 2d 64 4f 2d 76 | 41 72 20 69 6e 74 65 72 | ad-dO-v|Ar inter|
|00001120| 6e 20 75 6e 74 72 61 63 | 65 2d 66 75 6e 63 74 69 |n untrac|e-functi|
|00001130| 6f 6e 5d 20 33 20 22 5c | 0a 55 6e 74 72 61 63 65 |on] 3 "\|.Untrace|
|00001140| 73 20 61 6c 6c 20 63 75 | 72 72 65 6e 74 6c 79 20 |s all cu|rrently |
|00001150| 74 72 61 63 65 64 20 66 | 75 6e 63 74 69 6f 6e 73 |traced f|unctions|
|00001160| 2e 22 20 6e 69 6c 5d 29 | 0a 28 70 72 6f 76 69 64 |." nil])|.(provid|
|00001170| 65 20 28 71 75 6f 74 65 | 20 74 72 61 63 65 29 29 |e (quote| trace))|
|00001180| 0a | |. | |
+--------+-------------------------+-------------------------+--------+--------+